{{template "base" .}}

{{define "title"}}{{.Title}}{{end}}

{{define "extra_css"}}
<link href="{{.StaticURL}}/vendor/tempusdominus/css/tempusdominus-bootstrap-4.min.css" rel="stylesheet">
{{end}}

{{define "page_body"}}

<!-- Page Heading -->
<div class="card shadow mb-4">
    <div class="card-header py-3">
        <h6 class="m-0 font-weight-bold text-primary">{{.Title}}</h6>
    </div>
    <div class="card-body">
        {{if .Error}}
        <div class="card mb-4 border-left-warning">
            <div class="card-body text-form-error">{{.Error}}</div>
        </div>
        {{end}}
        {{if eq .Mode 3}}
        <div class="card mb-4 border-left-info">
            <div class="card-body">
                Generate a data provider independent JSON file to create new users or update existing ones.
                <br>
                The following placeholders are supported:
                <br><br>
                <ul>
                    <li><span class="text-success">%username%</span> will be replaced with the specified username</li>
                    <li><span class="text-success">%password%</span> will be replaced with the specified password</li>
                </ul>
                The generated users file can be imported from the "Maintenance" section.
                {{if .User.Username}}
                <br>
                Please note that no credentials were copied from user "{{.User.Username}}", you have to set them explicitly.
                {{end}}
            </div>
        </div>
        {{end}}
        <form id="user_form" enctype="multipart/form-data" action="{{.CurrentURL}}" method="POST" autocomplete="off" {{if eq .Mode 3}}target="_blank"{{end}}>
            {{if eq .Mode 3}}
            <div class="card bg-light mb-3">
                <div class="card-header">
                   Users
                </div>
                <div class="card-body">
                    <h6 class="card-title mb-4">For each user set the username and at least one of the password and public key</h6>
                    <div class="form-group row">
                        <div class="col-md-12 form_field_tpl_users_outer">
                            <div class="row form_field_tpl_user_outer_row">
                                <div class="form-group col-md-3">
                                    <input type="text" class="form-control" id="idTplUsername0" name="tpl_username" placeholder="Username" maxlength="255">
                                </div>
                                <div class="form-group col-md-3">
                                    <input type="password" class="form-control" id="idTplPassword0" name="tpl_password" placeholder="Password" maxlength="255">
                                </div>
                                <div class="form-group col-md-5">
                                    <textarea class="form-control" id="idTplPublicKey0" name="tpl_public_keys" rows="5"
                                        placeholder="Paste your public key here"></textarea>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_tpl_user_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                        </div>
                    </div>

                    <div class="row mx-1">
                        <button type="button" class="btn btn-secondary add_new_tpl_user_field_btn">
                            <i class="fas fa-plus"></i> Add new user
                        </button>
                    </div>
                </div>
            </div>
            <input type="hidden" name="username" id="idUsername" value="{{.User.Username}}">
            {{else}}
            <div class="form-group row">
                <label for="idUsername" class="col-sm-2 col-form-label">Username</label>
                <div class="col-sm-10">
                    <input type="text" class="form-control" id="idUsername" name="username" placeholder=""
                        value="{{.User.Username}}" maxlength="255" autocomplete="nope" required {{if ge .Mode 2}}readonly{{end}}>
                </div>
            </div>
            {{end}}

            <div class="form-group row">
                <label for="idEmail" class="col-sm-2 col-form-label">Email</label>
                <div class="col-sm-10">
                    <input type="text" class="form-control" id="idEmail" name="email" placeholder=""
                        value="{{.User.Email}}" maxlength="255" autocomplete="nope">
                </div>
            </div>

            <div class="form-group row">
                <label for="idDescription" class="col-sm-2 col-form-label">Description</label>
                <div class="col-sm-10">
                    <input type="text" class="form-control" id="idDescription" name="description" placeholder=""
                        value="{{.User.Description}}" maxlength="255" aria-describedby="descriptionHelpBlock">
                    <small id="descriptionHelpBlock" class="form-text text-muted">
                        Optional description, for example the user full name
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idStatus" class="col-sm-2 col-form-label">Status</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idStatus" name="status">
                        <option value="1" {{if eq .User.Status 1 }}selected{{end}}>Active</option>
                        <option value="0" {{if eq .User.Status 0 }}selected{{end}}>Inactive</option>
                    </select>
                </div>
            </div>

            <div class="form-group row">
                <label for="idExpirationDate" class="col-sm-2 col-form-label">Expiration Date</label>
                <div class="col-sm-10 input-group date" id="expirationDatePicker" data-target-input="nearest">
                    <input type="text" class="form-control datetimepicker-input" id="idExpirationDate"
                        data-target="#expirationDatePicker">
                    <div class="input-group-append" data-target="#expirationDatePicker" data-toggle="datetimepicker">
                        <div class="input-group-text"><i class="fas fa-calendar"></i></div>
                    </div>
                </div>
            </div>
            {{if ne .Mode 3}}
            <div class="form-group row">
                <label for="idPassword" class="col-sm-2 col-form-label">Password</label>
                <div class="col-sm-10">
                    <input type="password" class="form-control" id="idPassword" name="password" value="{{.User.Password}}" placeholder="">
                </div>
            </div>

            <div class="card bg-light mb-3">
                <div class="card-header">
                    Public keys
                </div>
                <div class="card-body">
                    <div class="form-group row">
                        <div class="col-md-12 form_field_pk_outer">
                            {{range $idx, $val := .User.PublicKeys}}
                            <div class="row form_field_pk_outer_row">
                                <div class="form-group col-md-11">
                                    <textarea class="form-control" id="idPublicKey{{$idx}}" name="public_keys" rows="3"
                                        placeholder="Paste your public key here">{{$val}}</textarea>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_pk_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{else}}
                            <div class="row form_field_pk_outer_row">
                                <div class="form-group col-md-11">
                                    <textarea class="form-control" id="idPublicKey0" name="public_keys" rows="3"
                                        placeholder="Paste your public key here"></textarea>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_pk_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{end}}
                        </div>
                    </div>

                    <div class="row mx-1">
                        <button type="button" class="btn btn-secondary add_new_pk_field_btn">
                            <i class="fas fa-plus"></i> Add new public key
                        </button>
                    </div>
                </div>
            </div>
            {{end}}

            <div class="form-group row">
                <label for="idTLSUsername" class="col-sm-2 col-form-label">TLS username</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idTLSUsername" name="tls_username" aria-describedby="tlsUsernameHelpBlock">
                        <option value="None" {{if eq .User.Filters.TLSUsername "None" }}selected{{end}}>None</option>
                        <option value="CommonName" {{if eq .User.Filters.TLSUsername "CommonName" }}selected{{end}}>Common Name</option>
                    </select>
                    <small id="tlsUsernameHelpBlock" class="form-text text-muted">
                        Defines the TLS certificate field to use as username. Ignored if mutual TLS is disabled
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idHomeDir" class="col-sm-2 col-form-label">Home Dir</label>
                <div class="col-sm-10">
                    <input type="text" class="form-control" id="idHomeDir" name="home_dir" placeholder=""
                        value="{{.User.HomeDir}}" maxlength="255">
                </div>
            </div>

            <div class="form-group row">
                <label for="idPermissions" class="col-sm-2 col-form-label">Permissions</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idPermissions" name="permissions" required multiple>
                        {{range $validPerm := .ValidPerms}}
                        <option value="{{$validPerm}}" {{range $perm :=$.RootDirPerms }}{{if eq $perm $validPerm}}selected{{end}}{{end}}>{{$validPerm}}</option>
                        {{end}}
                    </select>
                </div>
            </div>

            {{template "fshtml" .User.FsConfig}}
            {{if .VirtualFolders}}
            <div class="card bg-light mb-3">
                <div class="card-header">
                    Virtual folders
                </div>
                <div class="card-body">
                    <h6 class="card-title mb-4">Quota -1 means included within user quota, 0 unlimited. Don't set -1 for shared folders</h6>
                    <div class="form-group row">
                        <div class="col-md-12 form_field_vfolders_outer">
                            {{range $idx, $val := .User.VirtualFolders}}
                            <div class="row form_field_vfolder_outer_row">
                                <div class="form-group col-md-3">
                                    <input type="text" class="form-control" id="idVolderPath{{$idx}}" name="vfolder_path" placeholder="mount path, i.e. /vfolder" value="{{$val.VirtualPath}}" maxlength="255">
                                </div>
                                <div class="form-group col-md-3">
                                    <select class="form-control" id="idVfolderName{{$idx}}" name="vfolder_name">
                                        <option value=""></option>
                                        {{range $.VirtualFolders}}
                                        <option value="{{.Name}}" {{if eq $val.Name .Name}}selected{{end}}>{{.Name}}</option>
                                        {{end}}
                                    </select>
                                </div>
                                <div class="form-group col-md-3">
                                    <input type="number" class="form-control" id="idVfolderQuotaSize{{$idx}}" name="vfolder_quota_size"
                                        value="{{$val.QuotaSize}}" min="-1" aria-describedby="vqsHelpBlock{{$idx}}">
                                    <small id="vqsHelpBlock{{$idx}}" class="form-text text-muted">
                                        Quota size (bytes)
                                    </small>
                                </div>
                                <div class="form-group col-md-2">
                                    <input type="number" class="form-control" id="idVfolderQuotaFiles{{$idx}}" name="vfolder_quota_files"
                                        value="{{$val.QuotaFiles}}" min="-1" aria-describedby="vqfHelpBlock{{$idx}}">
                                        <small id="vqfHelpBlock{{$idx}}" class="form-text text-muted">
                                            Quota files
                                        </small>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_vfolder_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{else}}
                            <div class="row form_field_vfolder_outer_row">
                                <div class="form-group col-md-3">
                                    <input type="text" class="form-control" id="idVolderPath0" name="vfolder_path" placeholder="mount path, i.e. /vfolder" value="" maxlength="255">
                                </div>
                                <div class="form-group col-md-3">
                                    <select class="form-control" id="idVfolderName0" name="vfolder_name">
                                        <option value=""></option>
                                        {{range .VirtualFolders}}
                                        <option value="{{.Name}}">{{.Name}}</option>
                                        {{end}}
                                    </select>
                                </div>
                                <div class="form-group col-md-3">
                                    <input type="number" class="form-control" id="idVfolderQuotaSize0" name="vfolder_quota_size"
                                        value="" min="-1" aria-describedby="vqsHelpBlock0">
                                    <small id="vqsHelpBlock0" class="form-text text-muted">
                                        Quota size (bytes)
                                    </small>
                                </div>
                                <div class="form-group col-md-2">
                                    <input type="number" class="form-control" id="idVfolderQuotaFiles0" name="vfolder_quota_files"
                                        value="" min="-1" aria-describedby="vqfHelpBlock0">
                                        <small id="vqfHelpBlock0" class="form-text text-muted">
                                            Quota files
                                        </small>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_vfolder_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{end}}
                        </div>
                    </div>

                    <div class="row mx-1">
                        <button type="button" class="btn btn-secondary add_new_vfolder_field_btn">
                            <i class="fas fa-plus"></i> Add new virtual folder
                        </button>
                    </div>
                </div>
            </div>
            {{end}}

            <div class="card bg-light mb-3">
                <div class="card-header">
                    Per-directory permissions
                </div>
                <div class="card-body">
                    <div class="form-group row">
                        <div class="col-md-12 form_field_dirperms_outer">
                            {{range $idx, $dirPerms := .User.GetSubDirPermissions -}}
                            <div class="row form_field_dirperms_outer_row">
                                <div class="form-group col-md-8">
                                    <input type="text" class="form-control" id="idSubDirPermsPath{{$idx}}" name="sub_perm_path{{$idx}}" placeholder="directory path, i.e. /dir" value="{{$dirPerms.Path}}" maxlength="255">
                                </div>
                                <div class="form-group col-md-3">
                                    <select class="form-control" id="idSubDirPermissions{{$idx}}" name="sub_perm_permissions{{$idx}}" multiple>
                                        {{range $validPerm := $.ValidPerms}}
                                        <option value="{{$validPerm}}" {{range $perm := $dirPerms.Permissions }}{{if eq $perm $validPerm}}selected{{end}}{{end}}>{{$validPerm}}</option>
                                        {{end}}
                                    </select>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_dirperms_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{else}}
                            <div class="row form_field_dirperms_outer_row">
                                <div class="form-group col-md-8">
                                    <input type="text" class="form-control" id="idSubDirPermsPath0" name="sub_perm_path0" placeholder="directory path, i.e. /dir" value="" maxlength="255">
                                </div>
                                <div class="form-group col-md-3">
                                    <select class="form-control" id="idSubDirPermissions0" name="sub_perm_permissions0" multiple>
                                        {{range $validPerm := .ValidPerms}}
                                        <option value="{{$validPerm}}">{{$validPerm}}</option>
                                        {{end}}
                                    </select>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_dirperms_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{end}}
                        </div>
                    </div>

                    <div class="row mx-1">
                        <button type="button" class="btn btn-secondary add_new_dirperms_field_btn">
                            <i class="fas fa-plus"></i> Add new directory permissions
                        </button>
                    </div>
                </div>
            </div>

            <div class="form-group">
                <div class="form-check">
                    <input type="checkbox" class="form-check-input" id="idDisableFsChecks" name="disable_fs_checks"
                    {{if .User.Filters.DisableFsChecks}}checked{{end}} aria-describedby="disableFsChecksHelpBlock">
                    <label for="idDisableFsChecks" class="form-check-label">Disable filesystem checks</label>
                    <small id="disableFsChecksHelpBlock" class="form-text text-muted">
                        Disable checks for existence and automatic creation of home directory and virtual folders
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idQuotaSize" class="col-sm-2 col-form-label">Quota size (bytes)</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idQuotaSize" name="quota_size" placeholder=""
                        value="{{.User.QuotaSize}}" min="0" aria-describedby="qsHelpBlock">
                    <small id="qsHelpBlock" class="form-text text-muted">
                        0 means no limit
                    </small>
                </div>
                <div class="col-sm-2"></div>
                <label for="idQuotaFiles" class="col-sm-2 col-form-label">Quota files</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idQuotaFiles" name="quota_files" placeholder=""
                        value="{{.User.QuotaFiles}}" min="0" aria-describedby="qfHelpBlock">
                    <small id="qfHelpBlock" class="form-text text-muted">
                        0 means no limit
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idMaxUploadSize" class="col-sm-2 col-form-label">Max file upload size (bytes)</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idMaxUploadSize" name="max_upload_file_size"
                        placeholder="" value="{{.User.Filters.MaxUploadFileSize}}" min="0"
                        aria-describedby="fqsHelpBlock">
                    <small id="fqsHelpBlock" class="form-text text-muted">
                        0 means no limit
                    </small>
                </div>
                <div class="col-sm-2"></div>
                <label for="idMaxSessions" class="col-sm-2 col-form-label">Max sessions</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idMaxSessions" name="max_sessions" placeholder=""
                        value="{{.User.MaxSessions}}" min="0" aria-describedby="sessionsHelpBlock">
                    <small id="sessionsHelpBlock" class="form-text text-muted">
                        0 means no limit
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idUploadBandwidth" class="col-sm-2 col-form-label">Bandwidth UL (KB/s)</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idUploadBandwidth" name="upload_bandwidth"
                        placeholder="" value="{{.User.UploadBandwidth}}" min="0" aria-describedby="ulHelpBlock">
                    <small id="ulHelpBlock" class="form-text text-muted">
                        0 means no limit
                    </small>
                </div>
                <div class="col-sm-2"></div>
                <label for="idDownloadBandwidth" class="col-sm-2 col-form-label">Bandwidth DL (KB/s)</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idDownloadBandwidth" name="download_bandwidth"
                        placeholder="" value="{{.User.DownloadBandwidth}}" min="0" aria-describedby="dlHelpBlock">
                    <small id="dlHelpBlock" class="form-text text-muted">
                        0 means no limit
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idUID" class="col-sm-2 col-form-label">UID</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idUID" name="uid" placeholder="" value="{{.User.UID}}"
                        min="0" max="2147483647">
                </div>
                <div class="col-sm-2"></div>
                <label for="idGID" class="col-sm-2 col-form-label">GID</label>
                <div class="col-sm-3">
                    <input type="number" class="form-control" id="idGID" name="gid" placeholder="" value="{{.User.GID}}"
                        min="0" max="2147483647">
                </div>
            </div>

            <div class="form-group row">
                <label for="idProtocols" class="col-sm-2 col-form-label">Denied protocols</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idProtocols" name="denied_protocols" multiple>
                        {{range $protocol := .ValidProtocols}}
                        <option value="{{$protocol}}" {{range $p :=$.User.Filters.DeniedProtocols }}{{if eq $p $protocol}}selected{{end}}{{end}}>{{$protocol}}
                        </option>
                        {{end}}
                    </select>
                </div>
            </div>

            <div class="form-group row">
                <label for="idLoginMethods" class="col-sm-2 col-form-label">Denied login methods</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idLoginMethods" name="ssh_login_methods" multiple>
                        {{range $method := .ValidLoginMethods}}
                        <option value="{{$method}}" {{range $m :=$.User.Filters.DeniedLoginMethods }}{{if eq $m $method}}selected{{end}}{{end}}>{{$method}}
                        </option>
                        {{end}}
                    </select>
                </div>
            </div>

            <div class="form-group">
                <div class="form-check">
                    <input type="checkbox" class="form-check-input" id="idAllowAPIKeyAuth" name="allow_api_key_auth"
                    {{if .User.Filters.AllowAPIKeyAuth}}checked{{end}} aria-describedby="allowAPIKeyAuthHelpBlock">
                    <label for="idAllowAPIKeyAuth" class="form-check-label">Allow API key authentication</label>
                    <small id="allowAPIKeyAuthHelpBlock" class="form-text text-muted">
                        Allow to impersonate this user, in REST API, with an API key
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idDeniedIP" class="col-sm-2 col-form-label">Denied IP/Mask</label>
                <div class="col-sm-10">
                    <input type="text" class="form-control" id="idDeniedIP" name="denied_ip" placeholder=""
                        value="{{.User.GetDeniedIPAsString}}" maxlength="255" aria-describedby="deniedIPHelpBlock">
                    <small id="deniedIPHelpBlock" class="form-text text-muted">
                        Comma separated IP/Mask in CIDR format, for example "192.168.1.0/24,10.8.0.100/32"
                    </small>
                </div>
            </div>

            <div class="form-group row">
                <label for="idAllowedIP" class="col-sm-2 col-form-label">Allowed IP/Mask</label>
                <div class="col-sm-10">
                    <input type="text" class="form-control" id="idAllowedIP" name="allowed_ip" placeholder=""
                        value="{{.User.GetAllowedIPAsString}}" maxlength="255" aria-describedby="allowedIPHelpBlock">
                    <small id="allowedIPHelpBlock" class="form-text text-muted">
                        Comma separated IP/Mask in CIDR format, for example "192.168.1.0/24,10.8.0.100/32"
                    </small>
                </div>
            </div>

            <div class="card bg-light mb-3">
                <div class="card-header">
                    Per-directory file patterns
                </div>
                <div class="card-body">
                    <h6 class="card-title mb-4">Comma separated denied or allowed files, based on shell patterns</h6>
                    <div class="form-group row">
                        <div class="col-md-12 form_field_patterns_outer">
                            {{range $idx, $pattern := .User.GetFlatFilePatterns -}}
                            <div class="row form_field_patterns_outer_row">
                                <div class="form-group col-md-4">
                                    <input type="text" class="form-control" id="idPatternPath{{$idx}}" name="pattern_path{{$idx}}" placeholder="directory path, i.e. /dir" value="{{$pattern.Path}}" maxlength="255">
                                </div>
                                <div class="form-group col-md-5">
                                    <input type="text" class="form-control" id="idPatterns{{$idx}}" name="patterns{{$idx}}" placeholder="*.zip,?.txt" value="{{$pattern.GetCommaSeparatedPatterns}}" maxlength="255">
                                </div>
                                <div class="form-group col-md-2">
                                    <select class="form-control" id="idPatternType{{$idx}}" name="pattern_type{{$idx}}">
                                        <option value="denied" {{if $pattern.IsDenied}}selected{{end}}>Denied</option>
                                        <option value="allowed" {{if $pattern.IsAllowed}}selected{{end}}>Allowed</option>
                                    </select>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_pattern_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{else}}
                            <div class="row form_field_patterns_outer_row">
                                <div class="form-group col-md-4">
                                    <input type="text" class="form-control" id="idPatternPath0" name="pattern_path0" placeholder="directory path, i.e. /dir" value="" maxlength="255">
                                </div>
                                <div class="form-group col-md-5">
                                    <input type="text" class="form-control" id="idPatterns0" name="patterns0" placeholder="*.zip,?.txt" value="" maxlength="255">
                                </div>
                                <div class="form-group col-md-2">
                                    <select class="form-control" id="idPatternType0" name="pattern_type0">
                                        <option value="denied">Denied</option>
                                        <option value="allowed">Allowed</option>
                                    </select>
                                </div>
                                <div class="form-group col-md-1">
                                    <button class="btn btn-circle btn-danger remove_pattern_btn_frm_field">
                                        <i class="fas fa-trash"></i>
                                    </button>
                                </div>
                            </div>
                            {{end}}
                        </div>
                    </div>

                    <div class="row mx-1">
                        <button type="button" class="btn btn-secondary add_new_pattern_field_btn">
                            <i class="fas fa-plus"></i> Add new file pattern
                        </button>
                    </div>
                </div>
            </div>

            <div class="form-group row">
                <label for="idWebClient" class="col-sm-2 col-form-label">Web client/REST API</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idWebClient" name="web_client_options" multiple>
                        {{range $option := .WebClientOptions}}
                        <option value="{{$option}}" {{range $p :=$.User.Filters.WebClient }}{{if eq $p $option}}selected{{end}}{{end}}>{{$option}}
                        </option>
                        {{end}}
                    </select>
                </div>
            </div>

            <div class="form-group row">
                <label for="idHooks" class="col-sm-2 col-form-label">Hooks</label>
                <div class="col-sm-10">
                    <select class="form-control" id="idHooks" name="hooks" multiple>
                        <option value="external_auth_disabled" {{if .User.Filters.Hooks.ExternalAuthDisabled}}selected{{end}}>
                            External auth disabled
                        </option>
                        <option value="pre_login_disabled" {{if .User.Filters.Hooks.PreLoginDisabled}}selected{{end}}>
                            Pre-login disabled
                        </option>
                        <option value="check_password_disabled" {{if .User.Filters.Hooks.CheckPasswordDisabled}}selected{{end}}>
                            Check password disabled
                        </option>
                    </select>
                </div>
            </div>

            <div class="form-group row">
                <label for="idAdditionalInfo" class="col-sm-2 col-form-label">Additional info</label>
                <div class="col-sm-10">
                    <textarea class="form-control" id="idAdditionalInfo" name="additional_info" rows="3"
                        aria-describedby="additionalInfoHelpBlock">{{.User.AdditionalInfo}}</textarea>
                    <small id="additionalInfoHelpBlock" class="form-text text-muted">
                        Free form text field
                    </small>
                </div>
            </div>

            {{if eq .Mode 2}}
            <div class="form-group">
                <div class="form-check">
                    <input type="checkbox" class="form-check-input" id="idDisconnect" name="disconnect"
                        aria-describedby="disconnectHelpBlock">
                    <label for="idDisconnect" class="form-check-label">Disconnect the user after the update</label>
                    <small id="disconnectHelpBlock" class="form-text text-muted">
                        This way you force the user to login again, if connected, and so to use the new configuration
                    </small>
                </div>
            </div>
            {{end}}

            <input type="hidden" name="expiration_date" id="hidden_start_datetime" value="">
            <input type="hidden" name="_form_token" value="{{.CSRFToken}}">
            <button type="submit" class="btn btn-primary float-right mt-3 px-5 px-3">{{if eq .Mode 3}}Generate and export users{{else}}Submit{{end}}</button>
        </form>
    </div>
</div>
{{end}}

{{define "extra_js"}}
<script src="{{.StaticURL}}/vendor/moment/js/moment.min.js"></script>
<script src="{{.StaticURL}}/vendor/tempusdominus/js/tempusdominus-bootstrap-4.min.js"></script>
<script type="text/javascript">
    $(document).ready(function () {

        $('#expirationDatePicker').datetimepicker({
            format: 'YYYY-MM-DD',
            buttons: {
                showClear: false,
                showClose: true,
                showToday: false
            }
        });

        {{ if gt .User.ExpirationDate 0 }}
        var input_dt = moment({{.User.ExpirationDate }}).format('YYYY-MM-DD');
        $('#idExpirationDate').val(input_dt);
        $('#expirationDatePicker').datetimepicker('viewDate', input_dt);
        {{ end }}

        $("#user_form").submit(function (event) {
            var dt = $('#idExpirationDate').val();
            if (dt) {
                var d = $('#expirationDatePicker').datetimepicker('viewDate');
                if (d) {
                    var dateString = moment(d).format('YYYY-MM-DD HH:mm:ss');
                    $('#hidden_start_datetime').val(dateString);
                } else {
                    $('#hidden_start_datetime').val("");
                }
            } else {
                $('#hidden_start_datetime').val("");
            }
            return true;
        });

        onFilesystemChanged('{{.User.FsConfig.Provider.Name}}');

        $("body").on("click", ".add_new_pk_field_btn", function () {
            var index = $(".form_field_pk_outer").find(".form_field_pk_outer_row").length;
            while (document.getElementById("idPublicKey"+index) != null){
                index++;
            }
            $(".form_field_pk_outer").append(`
                    <div class="row form_field_pk_outer_row">
                        <div class="form-group col-md-11">
                            <textarea class="form-control" id="idPublicKey${index}" name="public_keys" rows="3"
                                placeholder="Paste your public key here"></textarea>
                        </div>
                        <div class="form-group col-md-1">
                            <button class="btn btn-circle btn-danger remove_pk_btn_frm_field">
                                <i class="fas fa-trash"></i>
                            </button>
                        </div>
                    </div>
                `);
        });

        $("body").on("click", ".remove_pk_btn_frm_field", function () {
            $(this).closest(".form_field_pk_outer_row").remove();
        });

        $("body").on("click", ".add_new_dirperms_field_btn", function () {
            var index = $(".form_field_dirperms_outer").find(".form_field_dirperms_outer_row").length;
            while (document.getElementById("idSubDirPermsPath"+index) != null){
                index++;
            }
            $(".form_field_dirperms_outer").append(`
                    <div class="row form_field_dirperms_outer_row">
                        <div class="form-group col-md-8">
                            <input type="text" class="form-control" id="idSubDirPermsPath${index}" name="sub_perm_path${index}" placeholder="directory path, i.e. /dir" value="" maxlength="255">
                        </div>
                        <div class="form-group col-md-3">
                            <select class="form-control" id="idSubDirPermissions${index}" name="sub_perm_permissions${index}" multiple>
                            </select>
                        </div>
                        <div class="form-group col-md-1">
                            <button class="btn btn-circle btn-danger remove_dirperms_btn_frm_field">
                                <i class="fas fa-trash"></i>
                            </button>
                        </div>
                    </div>
                `);

            {{range .ValidPerms}}
            $("#idSubDirPermissions"+index).append($('<option>').val('{{.}}').text('{{.}}'));
            {{end}}
        });

        $("body").on("click", ".remove_dirperms_btn_frm_field", function () {
            $(this).closest(".form_field_dirperms_outer_row").remove();
        });

        $("body").on("click", ".add_new_vfolder_field_btn", function () {
            var index = $(".form_field_vfolders_outer").find(".form_field_vfolder_outer_row").length;
            while (document.getElementById("idVolderPath"+index) != null){
                index++;
            }
            $(".form_field_vfolders_outer").append(`
                    <div class="row form_field_vfolder_outer_row">
                        <div class="form-group col-md-3">
                            <input type="text" class="form-control" id="idVolderPath${index}" name="vfolder_path" placeholder="mount path, i.e. /vfolder" value="" maxlength="255">
                        </div>
                        <div class="form-group col-md-3">
                            <select class="form-control" id="idVfolderName${index}" name="vfolder_name">
                                <option value=""></option>
                            </select>
                        </div>
                        <div class="form-group col-md-3">
                            <input type="number" class="form-control" id="idVfolderQuotaSize${index}" name="vfolder_quota_size"
                                value="" min="-1" aria-describedby="vqsHelpBlock${index}">
                            <small id="vqsHelpBlock${index}" class="form-text text-muted">
                                Quota size (bytes)
                            </small>
                        </div>
                        <div class="form-group col-md-2">
                            <input type="number" class="form-control" id="idVfolderQuotaFiles${index}" name="vfolder_quota_files"
                                value="" min="-1" aria-describedby="vqfHelpBlock${index}">
                            <small id="vqfHelpBlock${index}" class="form-text text-muted">
                                Quota files
                            </small>
                        </div>
                        <div class="form-group col-md-1">
                            <button class="btn btn-circle btn-danger remove_vfolder_btn_frm_field">
                                <i class="fas fa-trash"></i>
                            </button>
                        </div>
                    </div>
                `);

            {{range .VirtualFolders}}
            $("#idVfolderName"+index).append($('<option>').val('{{.Name}}').text('{{.Name}}'));
            {{end}}
        });

        $("body").on("click", ".remove_vfolder_btn_frm_field", function () {
            $(this).closest(".form_field_vfolder_outer_row").remove();
        });

        $("body").on("click", ".add_new_pattern_field_btn", function () {
            var index = $(".form_field_patterns_outer").find(".form_field_patterns_outer_row").length;
            while (document.getElementById("idPatternPath"+index) != null){
                index++;
            }
            $(".form_field_patterns_outer").append(`
                    <div class="row form_field_patterns_outer_row">
                        <div class="form-group col-md-4">
                            <input type="text" class="form-control" id="idPatternPath${index}" name="pattern_path${index}" placeholder="directory path, i.e. /dir" value="" maxlength="255">
                        </div>
                        <div class="form-group col-md-5">
                            <input type="text" class="form-control" id="idPatterns${index}" name="patterns${index}" placeholder="*.zip,?.txt" value="" maxlength="255">
                        </div>
                        <div class="form-group col-md-2">
                            <select class="form-control" id="idPatternType${index}" name="pattern_type${index}">
                                <option value="denied">Denied</option>
                                <option value="allowed">Allowed</option>
                            </select>
                        </div>
                        <div class="form-group col-md-1">
                            <button class="btn btn-circle btn-danger remove_pattern_btn_frm_field">
                                <i class="fas fa-trash"></i>
                            </button>
                        </div>
                    </div>
                `);
        });

        $("body").on("click", ".remove_pattern_btn_frm_field", function () {
            $(this).closest(".form_field_patterns_outer_row").remove();
        });

        $("body").on("click", ".add_new_tpl_user_field_btn", function () {
            var index = $(".form_field_tpl_users_outer").find(".form_field_tpl_user_outer_row").length;
            while (document.getElementById("idTplUsername"+index) != null){
                index++;
            }
            $(".form_field_tpl_users_outer").append(`
                    <div class="row form_field_tpl_user_outer_row">
                        <div class="form-group col-md-3">
                            <input type="text" class="form-control" id="idTplUsername${index}" name="tpl_username" placeholder="Username" maxlength="255">
                        </div>
                        <div class="form-group col-md-3">
                            <input type="password" class="form-control" id="idTplPassword${index}" name="tpl_password" placeholder="Password" maxlength="255">
                        </div>
                        <div class="form-group col-md-5">
                            <textarea class="form-control" id="idTplPublicKey${index}" name="tpl_public_keys" rows="5"
                                placeholder="Paste your public key here"></textarea>
                        </div>
                        <div class="form-group col-md-1">
                            <button class="btn btn-circle btn-danger remove_tpl_user_btn_frm_field">
                                <i class="fas fa-trash"></i>
                            </button>
                        </div>
                    </div>
                `);
        });

        $("body").on("click", ".remove_tpl_user_btn_frm_field", function () {
            $(this).closest(".form_field_tpl_user_outer_row").remove();
        });

    });

    {{template "fsjs"}}
</script>
{{end}}
